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PACKET QUEUING SYSTEM AND METHOD 
Background to the Invention 
Field of the Invention: 

The invention is related to the queuing of packets, and P 
particularly but not exclusively to the queuing of packets |gj 



at the input of a processing device 
Description of the Related Art: 
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A UNIX like operating system consists of a kernel, which is ' ^ 

the core of the operating system, and processes that are \ 

allocated CPU (central processor unit) run time by the I 

kernel. Different applications can be implemented as j fn 

processes. The kernel takes care of asynchronous events, \ O 

_ I o 

such as interrupts from hardware devices. The routines that I <Tp 

handle interrupts are called ''interrupt service routines" . 
The kernel also provides services for the processes. 

For high-speed devices, such as network interface cards, 
interrupts occur with a high priority. 

The frequency of interrupts depends on the frequency of the 
arriving packets. Even if interrupts are issued less 
frequently than packets arrive, the rate of interrupts can 
still be quite high. 

An interface card must acknowledge receipt of a packet 
quickly so that it can accept more packets. This is a 
relatively light process compared to processing of the 
actual packet. Therefore, the packets are usually placed on 
a work queue to be scheduled later on. This is done in 
order to avoid spending too much time in interrupt service 
routines and allow critical processes and other functions 
run- time. The mechanism for informing the kernel about 
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queued lower-priority work is termed a "software 
interrupt" . The processing of the packet is eventually 
handled by a function, and the packet is removed from the 
work queue. User space processes are pre-empted by both 

5 hardware and software interrupts. 

Queuing in this context refers to storing packets for 
subsequent processing. Typically, queuing occurs within any 
network device, such as a router, when packets are received 
by the device (input queue), and prior to transmitting the 

10 packets to another device (output queue) . By queuing the 
packets the device can tolerate variations in input/output 
processing. By queuing packets in multiple queues and 
applying scheduling (how packets are taken from the queues 
and moved onwards) the device can support quality of 

15 service. 

Quality of Service (QoS) is the end-to-end provision of a 
consistent, predictable data delivery service to a certain 
traffic class or user. Enabling QoS requires the 
cooperation of all network layers from top-to-bottom, as 

20 well as every network element from end-to-end. 

Packet traffic can be categorized by its requirements for 
delay and importance relative to other packet traffic. For 
example, traffic from a real-time service such as voice- 
over-IP requires low delay and low drop probability, 

25 whereas traffic from non- real- time service such as web 
browsing does not require such a strict delay 
characteristic nor does it matter so much if packets are 
dropped, because the traffic is protected by transmission 
control protocol (TCP) for HTTP traffic. 
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Differentiated Services (DiffServ) is an IETF specified QoS 
mechanism that handles traffic flows in one or more 
networks. In the DiffServ framework, packets carry 
information of their traffic class in the IP header. The 

5 Diffserv scheme does not require any signalling since 
packets are marked at source or at the edge of the network 
with priority information, and inside the network the 
packets are treated according to this information at each 
hop (i.e. at each step in the network such as a router). A 

10 key characteristic of Diffserv is that there are no 
absolute guarantees for any traffic class. The guarantees 
are relative to other traffic classes. For example, voice- 
over-IP is guaranteed to have the lowest drop probability 
and the lowest delay of. all traffic classes, whereas HTTP 

15 traffic suffers more in congestion situations in terms of 
packets dropped and experienced delay. Each packet is also 
treated the same way as others belonging to the same 
traffic class. 

Traditionally quality of service is enforced for packets 
20 which are going out of a network interface. Link 
congestion, where the network element transmits more 
packets than a network link can handle, is only part of the 
problem. Today network interfaces have a very large 
capacity and a typical general purpose processor can be 
25 easily overrun by packets arriving from the network. When 
the processor becomes overloaded packets are dropped 
randomly without any QoS treatment, and the existing QoS 
mechanisms become irrelevant. 

When a device receives packets, the packets can be dropped 
30 and/or experience delay in the various processing stages. 
Packets are especially likely to be dropped after interrupt 
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service routines and before actual packet processing. This 
happens because hardware interrupts are serviced (and 
interrupt service routines are run) at a higher priority 
than other tasks in the processor. When the hardware 

5 interrupt servicing takes less than 100% of CPU time, which 
is usually the case, the packets will be correctly placed 
to a queue waiting for further processing. If the queue 
becomes full packets are dropped. Since packets destined 
for a particular processing service are not typically 

10 queued in multiple queues, all packets arriving in that 
queue will be treated in the same manner (drop if queue is 
full) . High priority packets have the same drop probability 
and delay characteristics as low priority packets. 
Therefore, quality of service cannot be guaranteed in all 

15 processor and bus load situations. 

It is an aim of the invention to provide an improved 
technique for queuing packets. 

Summary of the Invention: 

According to the invention there is provided a method of 
20 queuing packets for processing, the method comprising the 
steps of: allocating each received packet to at least one 
arrival queue; placing each packet in the allocated queue 
if said queue is not full, otherwise dropping said packet; 
scheduling packets from the arrival queue to at least one 
25 transfer queue; responsive to transfer of a packet to a 
transfer queue, generating an interrupt; responsive to 
receipt of an interrupt, allocating the packet to one of a 
plurality of processor queues; placing the packet in the 
allocated processor queue if said queue is not full, 
30 otherwise dropping said packet; and scheduling packets from 
the processor queues for processing. 
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Packets may be received at an input to a plurality of 
devices . 

At least one device may include a plurality of arrival 
queues. Each arrival queue may be associated with a traffic 
5 class, each packet being allocated to the at least one 
queue in accordance with the traffic class of each packet. 
The traffic class may be priority information embedded in 
the each packet . 

At least one device may comprise a plurality of transfer 
10 queues. 

The number of transfer queues for each device may be less 
than the number of arrival queues for each device. 

The scheduling of packets from the arrival queue to the 
transfer queue may be dependent upon one or more of: the 
15 traffic profile; the quality of service requirement; or the 
characteristics of the transfer queues. 

The transfer queue may comprise a device level transfer 
queue and a processor level transfer queue, wherein the 
device level transfer queue receives packets from the 
20 arrival queue, and the processor level transfer queue 
receives packets from the device level transfer queue. 

Packets may be transferred to the processor level transfer 
queue from the device level transfer queue whenever there 
is space in the processor level transfer queue. 

25 Packets may never be dropped from the transfer queue. 

The processor queues may be associated with different 
priorities. The highest priority queue may have the lowest 
drop probability and the lowest latency. 
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Responsive to receipt of an interrupt from a device, a 
packet may be removed from the transfer queue of the device 
and classified. 

The classification may be based on a determination of 
5 priority, the packet may be allocated to a processor queue 
in accordance with its classification. The packet may be 
placed in the allocated processor queue if said queue is 
not full, otherwise the packet is dropped. 

In a further aspect the invention provides a system 
10 including a processor and at least one device, in which 
system: packets for processing by the processor are 
received at an input of the at least one device, wherein 
the at least one device includes: allocating means for 
allocating each received packet to at least one arrival 
15 queue of the device; placement means for placing each 
packet in the allocated queue if said queue is not full, 
otherwise dropping said packet; scheduling means for 
scheduling packets from the device arrival queue to at 
least one transfer queue; and interrupt means, responsive 
20 to transfer of a packet to a transfer queue, for generating 
an interrupt from the device to a processor; and wherein 
the processor includes: allocation means, responsive to 
receipt of an interrupt, for allocating the packet to one 
of a plurality of processor queues; placement means for 
25 placing the packet in the allocated processor queue if said 
queue is not full, otherwise dropping said packet;, and 
scheduling means for scheduling packets from the processor 
queues for processing. 

The system may include a plurality of devices adapted to 
30 receive packets for processing by the processor at inputs 
thereof . 
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At least one device may be adapted to provide a plurality 
of arrival queues 

Each arrival queue may be associated with a traffic class, 
each packet being allocated to the at least one queue by 
5 the allocation means in accordance with the traffic class 
of each packet. 

The traffic class may be priority information embedded in 
the each packet. 

At least one device may include a plurality of transfer 
10 queues. 

The number of transfer queues for each device may be less 
than the number of arrival queues for each device. 

The scheduling means may be responsive to one or more of: 
the traffic profile; the quality of service requirement; or 
15 the characteristics of the transfer queues. 

The transfer queue may comprise a device level transfer 
queue and a processor level transfer queue, the device 
level transfer queue being adapted to receive packets from 
the arrival queue, and the processor level transfer queue 
20 being adapted to receive packets from the device level 
transfer queue. 

The system may be adapted such that packets are transferred 
to the processor level transfer queue from the device level 
transfer queue whenever there is space in the processor 
25 level transfer queue. 

The system may be further adapted such that packets are 
never dropped from the transfer queue . 

The processor queues may be adapted to be associated with 
different priorities. 
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The system may be adapted such that the highest priority 
queue has the lowest drop probability and the lowest 
latency. 

The processor may include transfer means adapted, 
responsive to receipt of an interrupt from a device, to 
remove a packet from the transfer queue of the device, and 
provide such to a classification means for classification. 

The classification may be adapted to be based on a 
determination of priority. 

Embodiments of the invention relate to packet processing 
implemented in software running on a general purpose 
processor or similar system. 

Embodiments of the invention place packets into multiple 
queues after an interrupt service routine and before an 
actual packet processing in the following manner: the 
packet priority is read from the packet header; based on 
the packet priority the packet is placed on one of the 
queues; and there are 2 to N queues for a particular packet 
processing function. 

A scheduler with a suitable algorithm (s) then preferably 
moves packets from the N queues and passes them on to the 
appropriate packet processing stage. 

The invention, and embodiments thereof, thus provides flow 
control at a device level, preferably by means of a device 
level scheduler, to ensure that the processor only receives 
an amount of packets that it is able to process at the 
interrupt stage. 

The processor level scheduler, which is preferably 
provided, ensures that the quality of service rules are 
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followed in an overload situation for those packets that 
are already past the interrupt stage. 

Multiple queues are preferably provided at each stage. In 
some stages multiple queues are needed to make it possible 
5 to drop packets according to selected quality of service 
schemes . Preferably packets are dropped either at the 
arrival queues or at the last processor queues. In all 
stages, the preferable provision of multiple queues makes 
it possible to offer low delay to traffic classes that need 
10 that property. 

In a further aspect there is provided a device adapted for 
queuing packets to be processed, the device including: 
allocating means for allocating a received packet to at 
least one arrival queue; placement means for placing each 

15 packet in the allocated queue if said queue is not full, 
otherwise dropping said packet; scheduling means for 
scheduling packets from the arrival queue to at least one 
transfer queue; and interrupt means, responsive to transfer 
of a packet to a transfer queue, for generating an 

20 interrupt; allocation means, responsive to receipt of an 
interrupt, for allocating the packet to one of a plurality 
of processor queues; placement means for placing the packet 
in the allocated processor queue if said queue is not full, 
otherwise dropping said packet; and scheduling means for 

25 scheduling packets from the processor queues for 
processing. 

The device preferably includes a plurality of arrival 
queues 

Each arrival queue may be associated with a traffic class, 
30 each packet being allocated to the at least one queue by 
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the allocation means in accordance with the traffic class 
of each packet. 

The device may include a plurality of transfer queues. 
The transfer queue may comprise a device level transfer 
5 queue and a processor level transfer queue, tne device 
level transfer queue being adapted to receive packets from 
the arrival queue, and the processor level transfer queue 
being adapted to receive packets from the device level 
transfer queue. 

10 The device may be adapted such that packets are transferred 
to the processor level transfer queue from the device level 
transfer queue whenever there is space in the processor 
level transfer queue . 

The device may be further adapted such that packets are 
15 never dropped from the transfer queue. 

The processor queues may be adapted to be associated with 
different priorities. 

The device may further include transfer means adapted, 
responsive to receipt of an interrupt, to remove a packet 
20 from the transfer queue of, and provide such to a 
classification means for classification. 

The device may further include means to allocate the packet 
to a processor queue in accordance with its classification. 

The placement means may be adapted such that the packet is 
25 placed in the allocated processor queue if said queue is 
not full, and otherwise the packet is dropped. 

Brief Description of the Figures: 

The invention is described by way of example with reference 
to the accompanying drawings, in which: 
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Figure 1 illustrates an exemplary environment within which 
embodiments of the invention may be implemented; 

Figure 2 illustrates an exemplary implementation of a first 
part of a queuing arrangement in an embodiment of . the 
5 invention; 

Figure 3 illustrates preferred process steps for 
implementing an arrival queue in the embodiment of Figure 
2; 

Figure 4 illustrates preferred process steps for 
10 implementing for implementing a device transfer queue in 
the embodiment of Figure 2; 

Figure 5 illustrates an exemplary implementation of a 
second part of a queuing arrangement in an embodiment of 
the invention; and 

15 Figure 6 illustrates preferred process steps for 
implementing the embodiment of Figure 5. 

Description of Preferred Embodiments: 

The invention is described herein by way of reference to 
particular non-limiting examples. 

20 Referring to Figure 1, there is illustrated a typical 
example environment within which the invention may be 
implemented. A plurality of network devices 102,104,106 are 
shown. Each network device is provided with an interface to 
a bus 114. A chipset 108 is also provided with an interface 

25 to the bus 108. The chipset 108 is associated with a memory 
110 and a processor 112. 

The processor 112 processes packets received by the chipset 
108 on the bus 114. Packets are received by the chipset 108 
and stored or buffered in the memory 110 until the 
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processor 112 is ready to process them. The invention, and 
embodiments thereof, is utilised to control the buffering 
of data packets, as described in further detail below. 

The chipset 108 may, in practice, receive packets from any 
type of other device. For example, the chipset may receive 
packets from a switch fabric. The bus 114 may be any type 
of bus, for example a PCI bus, the processor 112 for 
example being a Pentium III processor or such like. There 
may also be provided multiple buses. The invention is not, 
however, limited to the packets being received on a bus. 

The invention will now be described by way of reference to 
a specific exemplary queuing arrangement as illustrated. 

Referring to Figure 2, there is illustrated a high level 
view of a processor ingress path for describing an 
exemplary embodiment of the invention. Reference numeral 
260 represents a processor and memory block, and reference 
numerals 202, 228, and 232 denote devices connected to the 
processor and memory block 260. In the exemplary 

embodiment, block 202 is a first network device, block 22 8 
is a second network device, and block 232 represents a 
switching fabric controller. The devices 202, 228, and 232 
are examples of devices that may be connected to the 
processor. Other devices may also be connected to the 
processor. In addition there may be more devices than the 
devices shown in Figure . 2 . 

The ingress path within the first network device 202 is now 
explained in further detail. The first network device 202 
receives arriving packets on an input line 2 04. The 
arriving packets on the input line 204 are received at a 
device input interface 206. The input interface 206 
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allocates the arriving packets to one or more arrival 
queues. The first network device 202 , in the exemplary 
embodiment, is provided with N arrival queues. Thus each 
arriving packet is allocated to one of N arrival queues, as 
5 denoted by queues 210i to 210 N . The input interface 206 is 
provided with N outputs, 208! to 208 N connected to each of 
the N arrival queues respectively. Each of the N arrival 
queues has a respective output 212 a to 212 N . Thus, in 
general, the input interface 206 allocates an arriving 
10 packet to one of the N arrival queues 210, the plurality of 
arrival queues 210 . having a corresponding plurality of 
inputs 208 and a corresponding plurality of outputs 212. 

Each individual device may be provided with a different 
number of arrival queues. Thus, N may be one or more for 
15 any device. 

Each of the N arrival queues is preferably associated with 
a particular traffic class. Thus, the input interface 206 
allocates arriving packets to the arrival queues in 
dependence upon the class of the arriving packets. When 
20 any arrival queue 210 becomes full, any packets destined 
for that queue are dropped. Thus all packets arriving at 
the input of the network device 2 02 are directed to one of 
the N arrival queues 210, in dependence on the traffic 
class associated with the respective packets. 

25 The traffic class used for allocating arriving packets to 
the arrival queues may be priority information embedded in 
the packets themselves . Each of the N queues may represent 
a certain traffic class, for example, a 3G network traffic 
class, a differentiated service traffic class, or a special 

30 plurality class for internal traffic or signalling traffic. 
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The outputs 212 a to 212 N of the arrival queues form inputs 
to a device level scheduler 214. The device level 
scheduler 214 transfers packets from the N arrival queues 
to M device transfer queues. The M device transfer queues 
are denoted by reference numeral 218, and comprise M device 
transfer queues 218 x to 218 M . The device level scheduler 
214 has a plurality M of outputs 216, denoted 216 2 to 216 M , 
each forming a respective input for one of the device 
transfer queues 218i to 218 M - The device transfer queues 
218i to 218 M have a respective plurality of M outputs, 
denoted 220i to 220 M . 

In the preferred embodiment, the number of device transfer 
queues M is less than or equal to the number of device 
arrival queues N. The mapping of the N queues to M queues 
depends on: (i) traffic profile; (ii) QoS requirement; and 
(iii) the characteristics of the transfer queues. In 
practice, the number of device transfer queues may be 
limited to only one or two queues. In an example where M ~ 
2, one queue may be used for the most important traffic 
class and all other traffic placed in the other queue. 
Thus each transfer queue 218 corresponds to a certain flow 
control and transfer functionality. 

The outputs 220i to 22 0 M of the device transfer queues 218 
form inputs to a device level interface 222. The device 
level interface provides outputs 226 x to 226 M to a processor 
level interface 262. 

The processor level interface 262 provides outputs on lines 
266 x to 266 M to respective processor transfer queues 264i to 
264 M . Each of the processor transfer queues has a 
respective output on lines 268i to 268 M . i 
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Thus, the packets in the device transfer queues 218 are 
transferred to corresponding processor transfer queues 264 . 
Each device transfer queue 218 therefore corresponds to a 
certain processor transfer queue 264 located in the 
5 processor part of the system 260. The number of processor 
transfer queues 264 corresponds to the number of device 
transfer queues. The processor transfer queues 264 are 
specific to the device 202. 

Packets are not dropped from the device transfer queues 218 
10 or the processor transfer queues 264. The device level 
scheduler 214 does not attempt to transfer packets to a 
device transfer queue 218 that does not have enough space 
in it . 

The purpose of the device level interface 222 and the 
15 processor level interface 262 are to provide flow control 
and transfer functionality to transfer packets from the 
device transfer queues 218 to the processor transfer queues 
264. The transfer of packets from any device transfer 
queue 218 to a respective processor transfer queue 264 
20 occurs whenever there is space in the particular processor 
transfer queue. The information of available space is 
communicated over a transfer bus via connections not 
illustrated in Figure 2, with any suitable algorithm or 
method as known in the art. 

25 Each other device connected to the processor and memory 
260, such as device of 228 and 232, is provided with 
arrival queues and device transfer queues as described 
hereinabove with reference to the first network device 202. 
For each of the second network device and the switching 

30 fabric controller 232, the packets arrive on a respective 
input line 230 and 234. . The arrival queues for each of the 
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devices 228 and 232 is not illustrated for simplification 
of the drawing. Each of the devices may have any number of 
arrival queues, being one or more, in dependence upon the 
configuration of the device. The packets in the arrival 
queues are allocated to device transfer queues by a device 
level scheduler, as described hereinabove with reference to 
the first network device 202. The device transfer queues 
for each of the second network device 22 8 and the switching 
fabric controller 232 are illustrated in Figure 2. 

The second network device 228 is provided with P device 
transfer queues 236, denoted 236 x to 236 P . The P device 
transfer queues each have a respective input line 240 x to 
240 P . The device transfer queues 236 each have a respective 
output 238i to 238 P , each of which forms an input to a 
device level interface 242 for the second network device 
228. As for any device, the number of device transfer 
queues may be any number of one or more. Thus P may be 
equal to any number. The device level interface 242 of the 
second network device 228 transfers packets in the P device 
transfer queues to corresponding P processor transfer 
queues in the processor and memory 260, as denoted by 
reference numerals 270i to 270 P . A processor level 
interface block 272 for the second network device 228 
receives the packets from the device level interface block 
242 on signal lines 244 a to 244 P . The processor level 
interface block 272 outputs the received packets on a 
respective output line 274i to 274 P , forming inputs to the 
respective ones of the P queues 270. The P queues 270 have 
respective outputs on output lines 276 x to 276 P . 

In the switching fabric controller 232, there are provided 
Q device transfer queues. Again, there may be one or more 
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arrival queues. In the example of the switching fabric 
controller 232, there is illustrated only a single device 
transfer queue, 248i. The device trasnfer queue has an 
input line 246 i; and an output line 250!. The output line 
5 is connected to a switch level interface 2 52 for the 
switching fabric controller 232. The switch, level 

interface 252 provides packets from the device transfer 
queue 248i on line 254 x to a processor level interface 278 
for the switching fabric controller 232. At the processor 
10 side, there is provided an equivalent number of processor 
transfer queues Q, in this example being one queue denoted 
282i. The processor level interface 278 provides packets on 
an output line 280 x to the queue 282i, which in turn has an 
output 284i. 

15 Referring further to Figure 2, it can be seen that each of 
the switch or device level interfaces 222, 242, or 252 
additionally generates an interrupt . The device level 
interface 222 generates an interrupt INT 1 on line 224, the 
device level interface 242 generates an interrupt INT 2 on 

20 line 256, and the switch level interface 252 generates an 
interrupt INT 3 on line 258. Each of the interrupts on 
lines 224, 256, 258, and the outputs of each of the 
processor transfer queues on lines 268, 276, and 284, are 
received as inputs by a processor and memory functionality 

25 block 286 of the processor and memory block 260. The 
operation of the processor and memory functionality block 
286 is described in further detail hereinbelow. 

Each of the processor transfer queues 264, 270, and 282 is 
located in the processor and memory part 260. The 
30 appropriate device notifies the processor and memory 260 
when it has transferred a certain amount of packets into 
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the processor transfer queues. After that, the processor 
and memory functionality block 286, as is described in 
further detail hereinbelow, selects one of the queues for 
processing. The selection -f the queue for processing may 
be based on any suitable algorithm, for example weighted 
round robin scheduling. The packet processing 

functionality of the processor and memory functionality 
block 286 then processes the packets one-by-one. 

At each stage, the highest priority queue is provided with 
the lowest drop probability and the lowest latency. 

In accordance with embodiments of the invention, multiple 
arrival queues are provided for queuing packets. In 
general, any number of 1 or more arrival queues may be 
provided. The arrival queues are preferably associated with 
priorities. Each incoming packet is then also preferably 
associated with a priority, which priority corresponds to a 
priority of one of the arrival queues. In a simple example, 
a packet may have one of two priorities, and two arrival 
queues each associated with a respective priority may be 
provided. In general, a packet may have one of ! n' 
priorities, and there may be provided ! n' arrival queues. 

It should be noted, however, that where n priorities are 
provided, there may be more than n arrival queues provided, 
certain arrival queues having the same priority. In 
general, it is preferred that there is at least one arrival 
queue for each priority. However, in practice this may not 
be the case, and multiple priorities may map to a single 
queue. 

It should also be noted that the length of the arrival 
queues for each priority may be the same or may be 
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different. Where it is known or expected that particular 
packets of a particular priority level will be prevalent; a 
longer arrival queue for such priority level may be 
provided. 

5 The operation of the invention in the specific arrangement 
of Figure 2 is now described with additional reference to 
the flowchart of Figure 3 . 

Referring to Figure 3, in a step 302 a packet is received 
at an input interface of a device, such as the input 

10 interface 206 of the first network device 202. In a step 
304, there is then determined a priority level of each 
arrival packet. As discussed above, preferably there is an 
arrival queue for each priority level, and the packet is 
then allocated to the appropriate arrival queue in step 

15 306. 

In the embodiments described herein, it is assumed that a 
priority of any given packet is indicated by a priority 
indicator included in the header of the packet. The 
identification and indication of a priority of a packet is 

20 outside the scope of the invention, and any known technique 
for denoting the priority of a packet may be used. The 
packet may have a field or multiple fields which can be 
used to find out its priority. The invention, or 
embodiments thereof, does not propose a new technique for 

25 allocating priorities to packets, or of identifying the 
priority of a packet within the packet. 

In a step 308 it is then determined whether the arrival 
queue to which the packet has been allocated is full. If 
the queue is full, then in step 310 the packet is dropped. 
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If the queue is not full, then in step 312 the packet is 
transferred to the arrival queue. 

Referring to Figure 4, the process steps in further 
handling the packets are described. In a step 4 02 the 
5 arrival queues, such as the N queues 210, are scheduled by 
the device level scheduler, such as scheduler 214. As 
such, the packets in the arrival queues are scheduled to 
the device transfer queues, such as M queues 218, in a step 
404. 

10 The scheduling mechanism may be any standard mechanism such 
as strict priority, round robin, or weighted round robin 
scheduling. It is not important how the scheduling is done 
or what header indicates the priority. Packets are 
scheduled from the arrival queues based on the respective 

15 priority of each arrival queue. 

The scheduling of packets from the arrival queues to the 
device transfer queues is in dependence on there being 
space available in the device transfer queues for the 
appropriate packets in the arrival queues . 

20 In a step 406, packets are transferred from the device 
transfer queues to the processor transfer queues. The flow 
of packets from the device transfer queues to the processor 
transfer queues is dependent upon space being available in 
the processor transfer queues. 

25 When a packet is transferred from a device transfer queue 
to a processor transfer queue, as denoted by step 408 an 
interrupt is generated to the processor. The handling of 
interrupts, and the further processing of packets, is 
described in further detail hereinbelow. 
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The flow of packets from the device transfer queues to the 
processor transfer queues may be by any conventional 
technique. Direct memory access (DMA) is a commonly used 
technique. The transfer queues may be DMA engines and 
5 their corresponding descriptor rings. If two DMA engines 
are provided, then two transfer queues are provided, one 
per engine. On the device side, packets are scheduled to 
the device transfer queues ready for transfer across the 
bus. When there is space on the processor side, i.e. in 
10 the corresponding queue in the processor memory, the DMA 
engine initiates a transfer and notifies the processor by 
interrupt after the transfer is complete. 

The queuing functionality in the device may be implemented 
in hardware (e.g. ASIC or FPGA) or in software (or 
15 firmware) running on a processor such as a network 
processor or a communications processor. 

In the embodiment described with reference to Figure 2, 
there is shown an example in which a transfer queue 
generally comprises a device level transfer queue or queues 
20 and a processor level transfer queue. The invention is not 
limited to such a specific queuing arrangement. 

In an alternative, the device level transfer queues may not 
be required, and packets may be transferred directly from 
the arrival queues to processor level transfer queues. An 
25 interrupt is generated in dependence on completion of a 
transfer of a packet to the processor level transfer queue. 

In a further alternative, the device may not transfer 
packets directly to the processor level transfer queues. A 
further interrupt stage may be incorporated, with packets 
30 being transferred from either the arrival queues or the 
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device level transfer queues to the processor level 
transfer queues in dependence upon generation of an 
interrupt signal . 

In general, the embodiments of the invention provide for a 
5 transfer queue to which packets are transferred from the 
arrival queues. The implementation of the transfer queue 
may vary, and the technique for the transport of packets 
from the arrival queues to the transfer queues may vary. 

Turning now to Figure 5, the impler ntation and operation 
10 of the processor and memory functionality block 286 of 
Figure 2 is further illustrated. As shown in Figure 5, the 
processor and memory functionality block 286 includes a 
classifier block 502, K queues 506i to 506 K , a processor 
level scheduler 510, and a process function 514. 

15 The classifier block 502 receives the outputs of each of 
the processor transfer queues 268, 276, and 284. In 
addition the classifier block 502 receives each of the 
interrupt signals INT 1, INT 2, INT 3 on each of lines 224, 
256, and 258 respectively. As is discussed further 

20 hereinbelow, the classifier block 502 allocates packets 
received from the packet transfer queues on lines 268, 276, 
and 284 to one of the K queues 506 x to 506 K . The classifier 
block 502 thus is provided with a plurality K of outputs 
504i to 504 K , each forming an input to one of the K queues. 

25 The K queues 506 are further provided with respective 
outputs 508x to 508 K , which forms inputs to the processor 
level scheduler 510. The output of the processor level 
scheduler on line 512 forms an input to the process 
function 514 . 
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The processor and memory functionality block 286 places the 
packets into K queues after an interrupt service routine 
and before the actual packet processing. 

As discussed hereinabove with reference to Figure 2, when a 
5 packet is transferred to one of the processor transfer 
queues an interrupt signal is generated by the device from 
which the packet originated. The packet then remains in 
the processor transfer queue pending execution of the 
interrupt. The further operation of the processor and 
10 memory functional . block 286 is now further described with 
reference to the flow processor of Figure 6. 

As denoted by step 602, the classifier block 502 receives 
an interrupt signal from an external device. Responsive 
thereto, the processor and memory functional block 286 
15 executes an interrupt service routine. 

In step 604, the packet is taken from the appropriate 
transfer queue, 268, 276 or 284, associated with the 
interrupt signal, by the classifier block 502. 

In a step 606, the classifier block 502 then classifies the 
20 packet. The classification of the packet may be based on a 
determination of the priority of the packet. The priority 
of the packet may be preferably determined by reading, an 
appropriate field of the packet header. 

Once the packet has been classified, then the appropriate 
25 one of the K queues to which the packet should be allocated 
is preferably known, as the packet is routed to the one of 
the K queues having the corresponding classification. This 
assumes that there is one queue available for each 
classification. There may be more or less than one queue 
30 available for each classification, in which case it is 
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necessary to make a further determination of the allocation 
of the packet to a queue . 

Once the queue to which the packet is to be allocated, 
based on classification, is determined, then the packet is 
5 placed in the appropriate one of the K queues, as denoted 
by step 608. Thus, the packet is transferred on one of the 
lines 504i to 504 K to the appropriate one of the queues 506i 
to 506 K . 

After the packet is allocated to a particular one of the K 
10 queues, it is determined in step 610 whether the queue is 
full. If the queue is full, then in step 612 the packet is 
dropped. If the queue is not full, then in step 614 the 
packet is transferred to the appropriate queue. 

Once the packet is placed in the queue, the interrupt 
15 routine is complete, as denoted by step 616. 

Once the packets are allocated to one of the K queues, the 
processor level scheduler 510 applies a suitable algorithm 
to transfer packets from the queues to an appropriate 
packet processing stage, as represented by the process 
20 function 514. In practice, there may be a plurality of 
process functions, and the processor level scheduler 510 
allocates the packet to the appropriate one of such 
plurality of process functions. 

As with the device level scheduler, the processor level 
25 scheduler 510 may be any scheduling mechanism, and" the 
implementation of the scheduler is outside the scope of the 
invention. The scheduler mechanism may, for example, be 
any standard mechanism such as strict priority, round 
robin, or weighted round robin scheduling. It is not 
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important to the invention, or embodiments thereof, as to 
how the scheduling is done. 

The processor and memory functional block 286 preferably 
handles overload situations by simply dropping packets from 
5 the queues that get full, (for example by 'tail drop' or 
one of the known RED algorithms) . By adjusting different 
parameters of the system (such as, for example, the number 
of queues, the queue depths, the queue selection algorithm, 
and the packet scheduling algorithm from the queues) the 
10 system can conform to selected differentiated services 
quality of service properties for each traffic class. 

The lowest priority queue of the K queues is typically most 
likely to drop packets and the highest priority queue is 
typically the least likely to drop packets. How this is 
15 achieved in practice depends on the selected scheduling 
mechanism, the queue length, the packet length etc. The 
lowest priority queue typically experiences the highest 
processing delays (latency) and delay variation. 

In summary, in embodiments the packets are received from a 
20 network device or a switching fabric over a bus at a 
memory. The device notifies a processor of the available 
packets in the processor memory by using an interrupt. The 
interrupt causes the CPU to invoke an interrupt service 
routine which transfers the packets from a received buffer 
25 in memory to one of a plurality of input queues. The queue 
is selected for each packet based on a classification, such 
as a priority field, in the packet header. 

Once allocated to a queue the packets wait for actual 
packet processing by the appropriate process function. If 
30 the process function is unable to handle packets at the 
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rate they arrive, individual queues may become full and 
packets may be dropped from such queues. The latency of the 
packets in lower priority queues may increase in times of 
congestion. 

5 An advantage of the invention is that the input direction 
(or ingress) queues may be made to comply with a selected 
quality of service (QoS) scheme, such as differentiated 
services, and packets may be treated according to the 
selected QoS scheme inside the system at all processing 
10 stages. 

As such, the traffic class drop probabilities relative to 
each other can be controlled in the input path, and the 
traffic class latency relative to each other can be 
controlled in the input path. 

15 In differentiated services, these two properties (drop 
probability and latency) determine the difference between 
two traffic classes. Therefore, they are very important 
properties that preferably should be controllable also 
inside the system. The invention provides this control. 

20 A further advantage of the invention is in the improvement 
of usable bandwidth, since the techniques of embodiments of 
the invention do not try to limit the inbound traffic for 
some traffic classes (those that have the highest 
priority) . The invention allows 100% processor utilization 

25 and may still provide adequate quality of service. 

A still further advantage of the invention is that it 
simplifies overload control, since there are not any 
specific overload tasks or polling. The detection of 
overload is embedded in the embodiments of the invention 
30 and happens on a per-packet basis at each of the stages 
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separately. It is not as expensive an operation in terms of 
CPU cycles as an additional overload control process, so 
the invention saves CPU time for the actual tasks. 

The invention guarantees that high priority packets are not 
5 likely to be dropped even if the CPU cannot process packets 
at the rate that they come in. This is different from other 
solutions that restrict the incoming packet rate, or start 
dropping packets from queues even before the queues get 
full. The invention guarantees similar quality of service 
10 treatment end-to-end (delay and drop probabilities) . 

The invention also guarantees that packets are treated 
according to their QoS profile at the packet processing 
stage (s) , even if there is no hardware support, and 
assuming that the interrupt stage does not consume all 
15 system resources. With the hardware support for ingress 
queues, this feature gives a full end- to- end queuing system 
for a processor ingress path. 

The invention may be implemented in any device where packet 
processing is based on a general purpose processor (CPU) 
20 and the enforcement of quality of service (QoS) is 
important. Such scenarios may, for example, be a serving 
GPRS support node and/ or a gateway GPRS support node in 3G 
and GPRS core networks. 

The invention may be especially advantageously implemented 
25 in devices that have network interface cards connected with 
a CPU using PCI or some other bus technology and network 
interface cards use DMA. (direct memory access) or a similar 
method to transfer data. 

The invention may be implemented in a system, where devices 
30 connect to a processor, as described herein by way of 
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preferred embodiments. The invention may also, however, 
apply to an implementation in a single device, where the 
arrival and transfer queues are provided as part of a 
single device. Such a device may be, for example, a network 
5 interface card, or a combination of interface hardware and 
a network processor, where the network processor implements 
a queuing structure toward a CPU or multiple CPUs. 

It should be noted that in the figures, for ease of 
explanation, there is shown dedicated lines for each 

10 priority/queue between various processing blocks. In a 
practical implementation, common bus/transfer resources may 
be used for all of the traffic classes, for example as a 
software function or as an electrical bus. The invention is 
thus not limited to the specifics of the exemplary 

15 implementation presented herein. 

The invention has been described herein by way of reference 
to particular exemplary embodiments. It will be understood, 
however, that the invention is not limited to the detail of 
such examples. The scope of protection afforded by the 

20 invention is set out in the appended claims. 
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